package cn.icatw.leetcode.editor.cn;
//给出由小写字母组成的字符串 S，重复项删除操作会选择两个相邻且相同的字母，并删除它们。
//
// 在 S 上反复执行重复项删除操作，直到无法继续删除。
//
// 在完成所有重复项删除操作后返回最终的字符串。答案保证唯一。
//
//
//
// 示例：
//
// 输入："abbaca"
//输出："ca"
//解释：
//例如，在 "abbaca" 中，我们可以删除 "bb" 由于两字母相邻且相同，这是此时唯一可以执行删除操作的重复项。之后我们得到字符串 "aaca"，其中又
//只有 "aa" 可以执行重复项删除操作，所以最后的字符串为 "ca"。
//
//
//
//
// 提示：
//
//
// 1 <= S.length <= 20000
// S 仅由小写英文字母组成。
//
//
// Related Topics 栈 字符串 👍 634 👎 0


import java.util.ArrayDeque;

//Java：删除字符串中的所有相邻重复项
public class T1047_RemoveAllAdjacentDuplicatesInString {
    public static void main(String[] args) {
        Solution solution = new T1047_RemoveAllAdjacentDuplicatesInString().new Solution();
        // TO TEST
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public String removeDuplicates(String s) {
            ArrayDeque<Character> deque = new ArrayDeque<>();
            for (char c : s.toCharArray()) {
                if (!deque.isEmpty() && deque.peek().equals(c)) {
                    deque.pop();
                } else {
                    deque.push(c);
                }
            }
            StringBuilder res = new StringBuilder();
            while (!deque.isEmpty()) {
                res.insert(0, deque.pop());
            }
            return res.toString();
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

}
